treeview: Use gtk_widget_queue_draw()
authorBenjamin Otte <otte@redhat.com>
Tue, 25 Oct 2016 05:25:59 +0000 (07:25 +0200)
committerBenjamin Otte <otte@redhat.com>
Thu, 27 Oct 2016 03:07:23 +0000 (05:07 +0200)
gtk/gtktreeview.c

index f4e4cb11760ec4a5f36ffe084c726ab4e11ac37c..010d09476b1261dbc59904fa92b071b809f9513e 100644 (file)
@@ -4523,6 +4523,33 @@ gtk_tree_view_update_rubber_band_selection (GtkTreeView *tree_view)
   tree_view->priv->rubber_band_end_node = end_node;
 }
 
+static void
+gtk_tree_view_invalidate_bin_region (GtkTreeView    *tree_view,
+                                     cairo_region_t *region)
+{
+  cairo_region_translate (region,
+                          - (gint) gtk_adjustment_get_value (tree_view->priv->hadjustment),
+                          gtk_tree_view_get_effective_header_height (tree_view));
+
+  cairo_region_intersect_rectangle (region,
+                                    &(GdkRectangle) { 0, 0,
+                                                      gdk_window_get_width (tree_view->priv->bin_window),
+                                                      gdk_window_get_height (tree_view->priv->bin_window)});
+
+  gtk_widget_queue_draw_region (GTK_WIDGET (tree_view), region);
+
+  cairo_region_destroy (region);
+}
+
+static void
+gtk_tree_view_invalidate_bin_area (GtkTreeView        *tree_view,
+                                   const GdkRectangle *rect)
+{
+  cairo_region_t *region = cairo_region_create_rectangle (rect);
+
+  gtk_tree_view_invalidate_bin_region (tree_view, region);
+}
+
 static void
 gtk_tree_view_update_rubber_band (GtkTreeView *tree_view)
 {
@@ -4559,9 +4586,7 @@ gtk_tree_view_update_rubber_band (GtkTreeView *tree_view)
   invalid_region = cairo_region_create_rectangle (&old_area);
   cairo_region_union_rectangle (invalid_region, &new_area);
 
-  gdk_window_invalidate_region (tree_view->priv->bin_window, invalid_region, TRUE);
-
-  cairo_region_destroy (invalid_region);
+  gtk_tree_view_invalidate_bin_region (tree_view, invalid_region);
 
   tree_view->priv->rubber_band_x = x;
   tree_view->priv->rubber_band_y = y;
@@ -4725,7 +4750,7 @@ invalidate_empty_focus (GtkTreeView *tree_view)
   area.y = 0;
   area.width = gdk_window_get_width (tree_view->priv->bin_window);
   area.height = gdk_window_get_height (tree_view->priv->bin_window);
-  gdk_window_invalidate_rect (tree_view->priv->bin_window, &area, FALSE);
+  gtk_tree_view_invalidate_bin_area (tree_view, &area);
 }
 
 /* Draws background and a focus rectangle near the edge of the bin_window;
@@ -6098,8 +6123,7 @@ gtk_tree_view_node_queue_redraw (GtkTreeView *tree_view,
   rect.width = gtk_widget_get_allocated_width (GTK_WIDGET (tree_view));
   rect.height = GTK_RBNODE_GET_HEIGHT (node);
 
-  gdk_window_invalidate_rect (tree_view->priv->bin_window,
-                             &rect, TRUE);
+  gtk_tree_view_invalidate_bin_area (tree_view, &rect);
 }
 
 static gboolean
@@ -9946,7 +9970,7 @@ gtk_tree_view_queue_draw_arrow (GtkTreeView        *tree_view,
   rect.y = gtk_tree_view_get_row_y_offset (tree_view, tree, node);
   rect.height = gtk_tree_view_get_row_height (tree_view, node);
 
-  gdk_window_invalidate_rect (tree_view->priv->bin_window, &rect, TRUE);
+  gtk_tree_view_invalidate_bin_area (tree_view, &rect);
 }
 
 void
@@ -9974,11 +9998,11 @@ _gtk_tree_view_queue_draw_node (GtkTreeView        *tree_view,
 
       gdk_rectangle_intersect (clip_rect, &rect, &new_rect);
 
-      gdk_window_invalidate_rect (tree_view->priv->bin_window, &new_rect, TRUE);
+      gtk_tree_view_invalidate_bin_area (tree_view, &new_rect);
     }
   else
     {
-      gdk_window_invalidate_rect (tree_view->priv->bin_window, &rect, TRUE);
+      gtk_tree_view_invalidate_bin_area (tree_view, &rect);
     }
 }